


//给你一个整数数组 nums ，请计算数组的 中心下标 。 
//
// 数组 中心下标 是数组的一个下标，其左侧所有元素相加的和等于右侧所有元素相加的和。 
//
// 如果中心下标位于数组最左端，那么左侧数之和视为 0 ，因为在下标的左侧不存在元素。这一点对于中心下标位于数组最右端同样适用。 
//
// 如果数组有多个中心下标，应该返回 最靠近左边 的那一个。如果数组不存在中心下标，返回 -1 。 
//
// 
//
// 示例 1： 
//
// 
//输入：nums = [1,7,3,6,5,6]
//输出：3
//解释：
//中心下标是 3 。
//左侧数之和 sum = nums[0] + nums[1] + nums[2] = 1 + 7 + 3 = 11 ，
//右侧数之和 sum = nums[4] + nums[5] = 5 + 6 = 11 ，二者相等。
// 
//
// 示例 2： 
//
// 
//输入：nums = [1, 2, 3]
//输出：-1
//解释：
//数组中不存在满足此条件的中心下标。 
//
// 示例 3： 
//
// 
//输入：nums = [2, 1, -1]
//输出：0
//解释：
//中心下标是 0 。
//左侧数之和 sum = 0 ，（下标 0 左侧不存在元素），
//右侧数之和 sum = nums[1] + nums[2] = 1 + -1 = 0 。 
//
// 
//
// 提示： 
//
// 
// 1 <= nums.length <= 10⁴ 
// -1000 <= nums[i] <= 1000 
// 
//
// 
//
// 
// 注意：本题与主站 724 题相同： https://leetcode-cn.com/problems/find-pivot-index/ 
//
// Related Topics 数组 前缀和 👍 40 👎 0


package cn.db117.leetcode.office;

/**
 * 剑指 Offer II 012.左右两边子数组的和相等.tvdfij
 *
 * @author db117
 * @since 2022-07-21 18:40:59
 **/

public class Offer_II012 {
    public static void main(String[] args) {
        Solution solution = new Offer_II012().new Solution();
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public int pivotIndex(int[] nums) {
            int[] preSum = new int[nums.length];

            for (int i = 0; i < nums.length; i++) {
                preSum[i] = nums[i];
                if (i > 0) {
                    preSum[i] += preSum[i - 1];
                }
            }

            for (int i = 0; i < nums.length; i++) {
                int left, right;
                if (i == 0) {
                    left = 0;
                } else {
                    left = preSum[i - 1];
                }

                if (i == nums.length - 1) {
                    right = 0;
                } else {
                    right = preSum[preSum.length - 1] - preSum[i];
                }
                if (left == right) {
                    return i;
                }
            }
            return -1;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}